草庐IT

sql - 读取 xsi :type from T-SQL

全部标签

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby-on-rails - 如何在 Ruby 中从下到上读取文件?

我一直在为Rails应用开发日志查看器,发现我需要从下到上阅读大约200行的日志文件,而不是默认的从上到下阅读。日志文件可能会变得非常大,所以我已经尝试并排除了IO.readlines("log_file.log")[-200..-1]方法。有没有其他方法可以在不需要插件或gem的情况下在Ruby中反向读取文件? 最佳答案 执行此操作且适用于大型文件的唯一正确方法是从末尾一次读取n个字节,直到获得所需的行数。这基本上就是Unixtail的工作方式。IO#tail(n)的示例实现,它将最后的n行作为Array返回:classIOTAI

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

ruby - 如何使用 Ruby 读取 Excel 电子表格的内容?

我正在尝试使用Ruby读取Excel电子表格文件,但它没有读取文件的内容。这是我的脚本book=Spreadsheet.open'myexcel.xls';sheet1=book.worksheet0sheet1.eachdo|row|putsrow.inspect;putsrow.format2;putsrow[1];exit;end它给了我以下信息:[DEPRECATED]Byrequiring'parseexcel','parseexcel/parseexcel'and/or'parseexcel/parser'youareloadingaCompatibilitylayerwh

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby - 如何使用 ruby​​ 的 net/imap 库读取电子邮件的正文?

可能是我今天脑子坏了,突然想不出怎么用ruby的net/imap库来阅读邮件了。我已经花了好几个小时了。我在谷歌中输入了“rubyimapreadbody”的几种变体,并浏览了许多网站。它们都有关于如何提取附件、同步电子邮件服务器、使用gmail等的示例……有些(如chilkat)实际上是为您执行此操作的共享软件库。我查看了net/imap文档,虽然有几个示例可以完成除阅读正文之外的所有操作。我以前使用过net/imap,但我只需要将收件箱中的附件下载到目录中。我在#ruby和#rubyonrails中询问都无济于事——没人能弄明白。imap=Net::IMAP.new('mail.x

ruby - 在 1.9.3 中读取文件时跳过第一行

我正在使用ruby​​的文件打开并读取rake中的文本文件任务。有没有一个设置可以指定我想要的第一行文件被跳过?到目前为止,这是我的代码:desc"Importusers."task:import_users=>:environmentdoFile.open("users.txt","r",'\r').eachdo|line|id,name,age,email=line.strip.split(',')u=User.new(:id=>id,:name=>name,:age=>age,:email=>email)u.saveendend我尝试了line.lineno也尝试了File.op

ruby-on-rails - 如何清理 Rails 4 中的原始 SQL

在Rails3中,我可以使用sanitize_sql_array为那些偶尔需要原始SQL查询的时刻清理原始SQL。但这似乎已在Rails4中删除,或者没有删除太多,而是移至ActiveRecord::Sanitization。但是,我现在不知道如何调用sanitize_sql_array,那么在Rails4中清理原始SQL的最佳方法是什么?我想澄清一下,我在这里谈论的是完整的原始SQL查询,而不是使用Rail的模型。我知道这不是最佳实践,这正是我必须为这个特定查询做的事情,因为它不能用Rails漂亮的ActiveRecord接口(interface)表示(相信我,我已经试过了)。这是一

sql - Ruby 中的 pretty-print SQL

有没有一种简单的方法可以在(rails3)控制台中pretty-print随机SQL?类似于awesome_print的内容,甚至可能是PrettyPrint.它不需要理解所有可能的方言或非常高级。我真正想要的是更轻松地检查ActiveRecord生成的SQL。目前我只是将SQL复制到网上进行格式化,这显然是生产力killer。我真的很想query.to_sql.pretty_format_sql并查看更好的输出。谢谢。 最佳答案 试试这个:gitclonehttps://github.com/sonota/anbt-sql-for